package com.zyb.warehouse.service;

import com.zyb.warehouse.common.Result;
import com.zyb.warehouse.dto.AssignAuthDto;
import com.zyb.warehouse.dto.Page;
import com.zyb.warehouse.entity.Role;

import java.util.List;

/**
 * Description:角色业务层接口
 */
public interface RoleService {

    /**
     * 获取所有角色信息
     *
     * @return
     */
    List<Role> queryRoleList();

    /**
     * 条件查询带分页
     *
     * @param page
     * @param role
     * @return
     */
    Page pageQuery(Page page, Role role);

    /**
     * 添加角色
     *
     * @param role
     * @param token
     * @return
     */
    Result addRole(Role role, String token);

    /**
     * 角色的启用或禁用
     *
     * @param role
     * @param token
     * @return
     */
    Result modifyRoleState(Role role, String token);

    /**
     * 修改角色
     *
     * @param role
     * @param token
     * @return
     */
    Result modifyRole(Role role, String token);

    /**
     * 删除角色
     *
     * @param roleId
     * @return
     */
    Result deleteRole(Integer roleId);

    /**
     * 根据角色ID查询已经分配给角色的权限
     *
     * @param roleId
     * @return
     */
    List<Integer> queryAllAuthByRoleId(Integer roleId);

    /**
     * 给角色分配权限（添加角色权限）
     *
     * @param assignAuthDto
     * @return
     */
    void addRoleAuth(AssignAuthDto assignAuthDto);
}
